package com.kk.mq.demo1.producer;

import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;

import java.io.IOException;
import java.util.concurrent.TimeoutException;

public class Producer_WorkQueue {
    public static void main(String[] args) throws IOException, TimeoutException {
        // 1、创建连接工厂
        ConnectionFactory factory = new ConnectionFactory ( );
        // 2、设置参数
        factory.setHost ("127.0.0.1");//ip  默认值 localhost
        factory.setPort (5672);//端口  默认值 5672
        factory.setVirtualHost ("/");//虚拟机 默认值/
        factory.setUsername ("guest");//用户名 默认 guest
        factory.setPassword ("guest");//密码 默认值 guest
        // 3、创建连接 Connection
        Connection connection = factory.newConnection ( );
        // 4、创建 Channel
        Channel channel = connection.createChannel ( );
        // 5、创建队列 Queue
        /*
         queueDeclare(String queue, boolean durable, boolean exclusive, boolean autoDelete, Map<String, Object> arguments)
         参数：
         1. queue：队列名称
         2. durable:是否持久化，当mq重启之后，数据还在
         3. exclusive：
             * 是否独占。只能有一个消费者监听这队列
             * 当Connection关闭时，是否删除队列
             *
         4. autoDelete:是否自动删除。当没有Consumer时，自动删除掉
         5. arguments：参数。
         */
        //如果没有一个名字叫work_queues的队列，则会创建该队列，如果有则不会创建
        channel.queueDeclare("work_queues",true,false,false,null);
        /*
        basicPublish(String exchange, String routingKey, BasicProperties props, byte[] body)
        参数：
            1. exchange：交换机名称。简单模式下交换机会使用默认的 ""
            2. routingKey：路由名称
            3. props：配置信息
            4. body：发送消息数据

         */
        for (int i = 1; i <= 10; i++) {
            String body = i+"work_queues~~~";
            //6. 发送消息
            channel.basicPublish("","work_queues",null,body.getBytes());
        }
        //7.释放资源
        channel.close ();
        connection.close ();
    }
}
